//给你单链表的头指针 head 和两个整数 left 和 right ，其中 left <= right 。请你反转从位置 left 到位置 right 的链
//表节点，返回 反转后的链表 。
// 
//
// 示例 1： 
//
// 
//输入：head = [1,2,3,4,5], left = 2, right = 4
//输出：[1,4,3,2,5]
// 
//
// 示例 2： 
//
// 
//输入：head = [5], left = 1, right = 1
//输出：[5]
// 
//
// 
//
// 提示： 
//
// 
// 链表中节点数目为 n 
// 1 <= n <= 500 
// -500 <= Node.val <= 500 
// 1 <= left <= right <= n 
// 
//
// 
//
// 进阶： 你可以使用一趟扫描完成反转吗？ 
// Related Topics 链表 👍 1340 👎 0


package leetcode.editor.cn;

/**
 * 反转链表 II
 * @date 2022-07-18 09:48:20
 */
class P92_ReverseLinkedListIi{
	 public static void main(String[] args) {
	 	 //测试代码
	 	 Solution solution = new P92_ReverseLinkedListIi().new Solution();
	 }
	 
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode reverseBetween(ListNode head, int left, int right) {
		ListNode dummyhead = new ListNode(-1,head);
		ListNode pre = dummyhead;
		ListNode p = head;
		if(left >= right || head == null){
			return head;
		}
		for (int i = 1; i < left; i++) {//pre指向要逆置节点的前一个节点
			pre = pre.next;
		}
		p = pre.next;//head指向逆置节点
		for (int i = left; i < right; i++) {
			ListNode temp = p.next;
			p.next = temp.next;//防止断链

			temp.next = pre.next;
			pre.next = temp;
		}
		return dummyhead.next;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
